home *** CD-ROM | disk | FTP | other *** search
/ Linux Cubed Series 7: Sunsite / Linux Cubed Series 7 - Sunsite Vol 1.iso / system / news / newspak-.5 / newspak- / newspak / docs / uucp-howto.asc < prev   
Text File  |  1995-11-23  |  19KB  |  661 lines

  1.   The Linux UUCP HOWTO
  2.   Vince Skahan, <vince@halcyon.com>
  3.   v1.11, 22 Oct 1994
  4.  
  5.   This document describes the setup and care+feeding of UUCP under
  6.   Linux.  You need to read this if you plan to connect to remote sites
  7.   via UUCP via a modem, via a direct-connection, or via Internet.  You
  8.   probably do *not* need to read this document if don't talk UUCP.
  9.  
  10.   1.  Introduction
  11.  
  12.   The intent of this document is to answer some of the questions and
  13.   comments that appear to meet the definition of "frequently asked
  14.   questions" about UUCP software under Linux in general, and the version
  15.   in the Linux SLS and Slackware distributions in particular.
  16.  
  17.   This document and the corresponding Mail and News "HOWTO" documents
  18.   collectively supersede the UUCP-NEWS-MAIL-FAQ that has previously been
  19.   posted to comp.os.linux.announce.
  20.  
  21.   1.1.    New versions of this document
  22.  
  23.   New versions of this document will be periodically posted to
  24.   comp.os.linux.announce, comp.answers, and news.answers.  They will
  25.   also be added to the various anonymous ftp sites who archive such
  26.   information including sunsite.unc.edu:/pub/Linux/docs/HOWTO.
  27.  
  28.   In addition, you should be generally able to find this document on the
  29.   Linux WorldWideWeb home page at http://sunsite.unc.edu/mdw/linux.html
  30.   and on my home page at http://www.halcyon.com/vince/welcome.html.
  31.  
  32.  
  33.   1.2.    Feedback
  34.  
  35.   I am interested in any feedback, positive or negative, regarding the
  36.   content of this document via e-mail.    Definitely contact me if you
  37.   find errors or obvious omissions.
  38.  
  39.   I read, but do not necessarily respond to, all e-mail I receive.
  40.   Requests for enhancements will be considered and acted upon based on
  41.   that day's combination of available time, merit of the request, and
  42.   daily blood pressure :-)
  43.  
  44.   Flames will quietly go to /dev/null so don't bother.
  45.  
  46.   Feedback concerning the actual format of the document should go to the
  47.   HOWTO coordinator - Matt Welsh (mdw@sunsite.unc.edu).
  48.  
  49.  
  50.   1.3.    Copyright Information
  51.  
  52.   The UUCP-HOWTO is copyrighted (c)1994 Vince Skahan.
  53.  
  54.   A verbatim copy may be reproduced or distributed in any medium
  55.   physical or electronic without permission of the author.  Translations
  56.   are similarly permitted without express permission if it includes a
  57.   notice on who translated it.
  58.  
  59.   Short quotes may be used without prior consent by the author.
  60.   Derivative work and partial distributions of the UUCP-HOWTO must be
  61.   accompanied with either a verbatim copy of this file or a pointer to
  62.   the verbatim copy.
  63.  
  64.   Commercial redistribution is allowed and encouraged; however, the
  65.   author would like to be notified of any such distributions.
  66.  
  67.   In short, we wish to promote dissemination of this information through
  68.   as many channels as possible. However, we do wish to retain copyright
  69.   the HOWTO documents, and would like to be notified of any plans to
  70.   redistribute the HOWTOs.
  71.  
  72.   We further want that ALL information provided in the HOWTOS is
  73.   disseminated.    If you have questions, please contact Matt Welsh, the
  74.   Linux HOWTO coordinator, at mdw@sunsite.unc.edu, or +1 607 256 7372.
  75.  
  76.  
  77.   1.4.    Standard Disclaimer
  78.  
  79.   Of course, I disavow any potential liability for the contents of this
  80.   document.  Use of the concepts, examples, and/or other content of this
  81.   document is entirely at your own risk.
  82.  
  83.  
  84.   1.5.    Other sources of information
  85.  
  86.   1.5.1.  Linux HOWTO Documents
  87.  
  88.   There is plenty of exceptional material provided in the other Linux
  89.   HOWTO documents and from the Linux DOC project.  In particular, you
  90.   might want to take a look at the following:
  91.  
  92.  
  93.   o  the Serial Communications HOWTO
  94.  
  95.   o  the Ethernet HOWTO
  96.  
  97.   o  the Linux Networking Administrators' Guide
  98.  
  99.  
  100.   1.5.2.  USENET
  101.  
  102.   comp.mail.uucp can answer most of your UUCP questions
  103.  
  104.   1.5.3.  Mailing Lists
  105.  
  106.   There is a Taylor UUCP mailing list.
  107.  
  108.   To join (or get off) the list, send mail to
  109.  
  110.         taylor-uucp-request@gnu.ai.mit.edu
  111.  
  112.  
  113.  
  114.   This request goes to a person, not to a program, so please make sure
  115.   that you include the address at which you want to receive mail in the
  116.   text of the message.
  117.  
  118.   To send a message to the list, send it to
  119.  
  120.            taylor-uucp@gnu.ai.mit.edu
  121.  
  122.  
  123.  
  124.  
  125.   1.5.4.  Books
  126.  
  127.   HDB and V2 versions of UUCP are documented in about every vendor's
  128.   documentation as well as in almost all *nix communications books.
  129.  
  130.   Taylor config files are currently only documented in the info files
  131.   provided with the sources (and in the SLS distribution hopefully).  To
  132.   read them, you can grab the nice "infosrc" program from the SLS "s"
  133.   disks and compile it.
  134.  
  135.   The following is a non-inclusive set of books that will help.
  136.  
  137.   o  "Managing UUCP and USENET" from O'Reilly and Associates is in my
  138.      opinion the best book out there for figuring out the programs and
  139.      protocols involved in being a USENET site.
  140.  
  141.   o  "Unix Communications" from The Waite Group contains a nice
  142.      description of all the pieces (and more) and how they fit together.
  143.  
  144.   o  "Practical Unix Security" from O'Reilly and Associates has a nice
  145.      discussion of how to secure UUCP in general.
  146.  
  147.   o  "The Internet Complete Reference" from Osborne is a fine reference
  148.      book that explains the various services available on Internet and
  149.      is a great source for information on news, mail, and various other
  150.      Internet resources.
  151.  
  152.   o  "The Linux Networking Administrators' Guide" from Olaf Kirch of the
  153.      Linux DOC Project is available on the net and is also published by
  154.      (at least) O'Reilly and SSC.  It makes a fine one-stop shopping to
  155.      learn about everything you ever imagined you'd need to know about
  156.      Unix networking.
  157.  
  158.  
  159.   1.6.    Where *NOT* to look for help
  160.  
  161.   There is nothing "special" about configuring and running UUCP under
  162.   Linux (any more).  Accordingly, you almost certainly do *NOT* want to
  163.   be posting generic UUCP-related questions to the comp.os.linux.*
  164.   newsgroups.
  165.  
  166.   Unless your posting is truly Linux-specific (ie, "please tell me what
  167.   config file support is built into the binaries for Taylor uucp v1.04
  168.   in SLS v1.02"), you should be asking your questions in comp.mail.uucp
  169.   or on the Taylor UUCP mailing list as indicated above.
  170.  
  171.   Let me repeat that.
  172.  
  173.   There is virtually no reason to post anything uucp-related in the
  174.   comp.os.linux hierarchy any more.  There are existing newsgroups in
  175.   the comp.mail.* hierarchy to handle *ALL* your questions.
  176.  
  177.   IF YOU POST TO COMP.OS.LINUX.* FOR NON-LINUX-SPECIFIC QUESTIONS, YOU
  178.   ARE LOOKING IN THE WRONG PLACE FOR HELP.  THE UUCP EXPERTS HANG OUT IN
  179.   THE PLACES INDICATED ABOVE AND GENERALLY DO NOT RUN LINUX.
  180.  
  181.   POSTING TO THE LINUX HIERARCHY FOR NON-LINUX-SPECIFIC QUESTIONS WASTES
  182.   YOUR TIME AND EVERYONE ELSE'S AND IT FREQUENTLY DELAYS YOU FROM
  183.   GETTING THE ANSWER TO YOUR QUESTION.
  184.  
  185.  
  186.   2.  Hardware Requirements
  187.  
  188.  
  189.   There are no specific hardware requirements for UUCP under Linux.
  190.   Basically any Hayes-compatible modem works painlessly with UUCP.
  191.  
  192.   In most cases, you'll want the fastest modem you can afford.    In
  193.   general, you want to have a 16550 UART on your serial board or built
  194.   into your modem to handle speeds of above 9600 baud.
  195.  
  196.   If you don't know what that last sentence means, please consult the
  197.   comp.dcom.modems group or the various fine modem and serial
  198.   communications FAQs and periodic postings on USENET.
  199.   3.  Getting UUCP
  200.  
  201.   Taylor UUCP (current version 1.05) is available on prep.ai.mit.edu in
  202.   source form and in various Linux distributions in binary form.
  203.  
  204.   The newspak-2.4.tar.z distribution contains config files and readme
  205.   files related to building uucp, news, and mail software under Linux
  206.   from the various freely-available sources.  It can usually be found on
  207.   sunsite.unc.edu in the directory /pub/Linux/system/Mail/news.    If you
  208.   can't find it on sunsite, please send me mail and I'll make sure you
  209.   get a copy of it.
  210.  
  211.  
  212.   4.  Installing the Software
  213.  
  214.   (Much of this section is taken verbatim from the README file in the
  215.   Taylor UUCP v1.05 sources - it's provided here so I can help you
  216.   "rtfm" instead of just telling you to do so)
  217.  
  218.   Detailed compilation instructions are in uucp.texi in the sources.
  219.  
  220.   You can grab "known good" conf.h and policy.h files for Linux from the
  221.   newspak distribution referred to in the "other sources of information"
  222.   section above.  In that case, you can probably go right to typing
  223.   "make".
  224.  
  225.  
  226.   4.1.    Extracting the compressed sources
  227.  
  228.   To extract a gzip'd tar archive, I do the following:
  229.  
  230.           gunzip -c filename.tar.z | tar xvf -
  231.  
  232.  
  233.   A "modern" tar can just do a:
  234.  
  235.          tar -zxvf filename.tgz
  236.  
  237.  
  238.  
  239.   4.2.    Edit Makefile.in to set installation directories.
  240.  
  241.   Here, I set "prefix" to "/usr" rather than the default of "/usr/local"
  242.  
  243.  
  244.   4.3.    Run "configure"
  245.  
  246.   Type "sh configure".
  247.  
  248.   The configure script will compile a number of test programs to see
  249.   what is available on your system and will calculate many things.
  250.  
  251.   The configure script will create conf.h from conf.h.in and Makefile
  252.   from Makefile.in.  It will also create config.status, which is a shell
  253.   script which actually creates the files.
  254.  
  255.  
  256.   o  Rather than editing the Makefile.in file in the sources as
  257.      indicated above, you can get the same effect by:
  258.  
  259.          "configure --prefix=/usr/lib"
  260.  
  261.  
  262.  
  263.  
  264.  
  265.   4.4.    Configure the future setup of the software
  266.  
  267.  
  268.   4.4.1.  Examine conf.h and Makefile to make sure they're right.
  269.  
  270.   I took the defaults
  271.  
  272.   4.4.2.  Edit policy.h for your local system.
  273.  
  274.  
  275.   o  - set the type of lockfiles you want (HAVE_HDB_LOCKFILES)
  276.  
  277.   o  - set the type of config files you want built in
  278.      (HAVE_TAYLOR_CONFIG, HAVE_V2_CONFIG, HAVE_HDB_CONFIG)
  279.  
  280.   o  - set the type of spool directory structure you want (SPOOLDIR_HDB)
  281.  
  282.   o  - set the type of logging you want (HAVE_HDB_LOGGING)
  283.  
  284.   o  - set the default search path for commands (I added /usr/local/bin
  285.      to mine)
  286.  
  287.   4.5.    Compile and install the software
  288.  
  289.  
  290.   o  Type "make".
  291.  
  292.   o  Use "uuchk | more" to check configuration files.  You can use
  293.      "uuconv" to convert between configuration file formats.
  294.  
  295.   o  Type "make install" to install.
  296.  
  297.   4.6.    Set up the config files
  298.  
  299.   I'd recommend you start by taking the attached known-good config files
  300.   for HDB mode and installing them.
  301.  
  302.   o  Make sure that the Permissions file indicates exactly where rmail
  303.      and rnews are to be found if you put them anywhere other than in
  304.      the path you specified in policy.h
  305.  
  306.   o  Make sure that your Devices files matches the actual location of
  307.      your modem (cua1=COM2 in the examples)
  308.  
  309.   o  Edit the Systems file to set up the system(s) you talk to with
  310.      their speed, phone number, username, and password.
  311.  
  312.      *PROTECT THIS FILE AGAINST WORLD READ*
  313.  
  314.   o  Set up the Permissions file and add a set of lines for each site
  315.      you talk to.  For security reasons, it's recommended to make sure
  316.      they each have a separate account (if you allow dialin) and home
  317.      directory so you can track things.
  318.  
  319.  
  320.   4.7.    Give it a try
  321.  
  322.  
  323.  
  324.       /usr/lib/uucp/uucico -r 1 -x 9 -s remote_system_name
  325.  
  326.  
  327.  
  328.   The -x 9 will have maximum debugging information written to the
  329.   /usr/spool/uucp/.Admin/audit.local file for help in initial setup.
  330.  
  331.   I normally run -x 4 here since that level logs details that help me
  332.   with login problems.    Obviously, this contains cleartext information
  333.   from your Systems file (account/password) so protect it against world-
  334.   read.
  335.  
  336.  
  337.   o  from Pierre.Beyssac@emeraude.syseca.fr
  338.  
  339.      Taylor has more logging levels.  Use -x all to get the highest
  340.      level possible.
  341.  
  342.      Also, do a "tail -f /usr/spool/uucp/.Admin/audit.local" while
  343.      debugging to watch things happen on the fly.
  344.  
  345.   4.8.    It doesn't work - now what ?
  346.  
  347.   In general, you can refer to the documentation mentioned above if
  348.   things don't work.  You can also refer to your more experienced UUCP
  349.   neighbors for help.  Usually, it's something like a typo anyway.
  350.  
  351.  
  352.   5.  Frequently Asked Questions about Linux UUCP
  353.  
  354.  
  355.  
  356.   5.1.    Why is my binary of uucp configured in HDB rather than "Taylor"
  357.   mode?
  358.  
  359.   (religious mode on - I know some people are just as religious about
  360.   "ease of use" as I am about "being standard".    That's why they make
  361.   source code you can build your own from :-) )
  362.  
  363.   Because IMHO it's the de-facto standard UUCP implementation at this
  364.   time.    There are thousands of sites with experienced admins and there
  365.   are many places you can get incredibly good information concerning the
  366.   HDB setup.
  367.  
  368.   The uucp-1.04 that's in SLS 1.02 and later has all three modes of
  369.   config files built in.  While I can't test it, I did "rtfm" and Ian
  370.   Taylor tells me that it should work.
  371.  
  372.   The search order for config files is Taylor then V2 (L.sys)  then HDB.
  373.   Use the uuconv utility in /usr/lib/uucp to convert config files from
  374.   one mode to another.
  375.  
  376.   If you can't wait, grab the sources for uucp and specify
  377.   HAVE_BNU_CONFIG, HAVE_V2_CONFIG *and* HAVE_TAYLOR_CONFIG in the
  378.   policy.h file and type "make".
  379.  
  380.   The following workaround is ugly, but it does work, if you want to run
  381.   Taylor configs from binaries that don't have it built in.
  382.  
  383.   o  From mbravo@tctube.spb.su (Michael E. Bravo)
  384.  
  385.      - add  "-I /usr/local/lib/uucp/config" to _every_ invocation of
  386.      whatever program in uucp package
  387.  
  388.   5.2.    Why do I get "timeout" on connections when I upgraded to
  389.   uucp-1.04 ?
  390.  
  391.  
  392.   o  from Ed Carp - erc@apple.com
  393.  
  394.      If you use a "Direct" device in the Devices file, there's now a 10
  395.      second timeout compiled in.  Make the name of the Device anything
  396.      other than "Direct".  If you tweak the example /usr/lib/uucp files
  397.      provided with SLS, you won't have problems with this one.
  398.  
  399.   o  from Greg Naber - greg@squally.halcyon.com
  400.  
  401.      If you get chat script timeouts, you can tweak the sources by
  402.      editing at line 323 in uuconf/syssub.c and changing the default
  403.      timeouts from 10 seconds to something larger.
  404.  
  405.   o  from Ed Rodda - ed@orca.wimsey.bc.ca
  406.  
  407.      If you get chat script timeouts, typically connecting to other
  408.      Taylor sites, a pause after login can fix this.
  409.  
  410.      feed Any ACU,ag 38400 5551212 ogin: \c\d "" yourname word: passwd
  411.  
  412.  
  413.  
  414.   o  from Dr. Eberhard W. Lisse - el@lisse.NA
  415.  
  416.      Some kernels experience modems hanging up after a couple of
  417.      seconds.  The following patch sent by Ian Taylor might help.
  418.  
  419.      *** conn.c.orig Mon Feb 22 20:25:24 1993
  420.      --- conn.c    Mon Feb 22 20:33:10 1993
  421.      ***************
  422.      *** 204,209 ****
  423.      --- 204,212 ----
  424.  
  425.       /* Make sure any signal reporting has been done before we set
  426.         fLog_sighup back to TRUE.  */
  427.      +    /* SMR: it seems to me if we don't care about SIGHUPS, we should clear
  428.      +    the flag before we return  */
  429.      +    afSignal[INDEXSIG_SIGHUP] = FALSE;
  430.      ulog (LOG_ERROR, (const char *) NULL);
  431.      fLog_sighup = TRUE;
  432.  
  433.  
  434.  
  435.   5.3.    Why doesn't HDB anonymous uucp seem to work ?
  436.  
  437.   The SLS anonymous uucp only works in Taylor mode because it's compiled
  438.   with HAVE_TAYLOR_CONFIG.  If you want to do anon uucp in HDB mode,
  439.   you'll have to recompile the sources with just HDB defined.  Ian
  440.   Taylor is considering which way to deal with this "feature".
  441.  
  442.   Also, Taylor in HDB mode seems to be sensitive to white space and
  443.   blank lines.    To be safe, make sure that there are no blank lines or
  444.   trailing spaces in the Permissions file.
  445.  
  446.   Lastly, make sure that you have a file called remote.unknown in
  447.   /usr/lib/uucp and that it's *NOT* executable.    See the O'Reilly+Assoc
  448.   book "Managing UUCP and USENET" for details regarding this file.
  449.  
  450.  
  451.   5.4.    What does "no matching ports found" mean ?
  452.  
  453.   In all probability, you are attempting to use a device
  454.   (/usr/lib/uucp/Devices) that doesn't exist, or the device you've
  455.   specified in the /usr/lib/uucp/Systems file doesn't match up with any
  456.   valid devices in the Devices file.
  457.  
  458.   Following this are *sanitized* versions of my working Taylor 1.05 HDB
  459.   config files that you can plug in and use.
  460.  
  461.   note the "ACU" in the Systems ?  That tells which "port" to use in
  462.   Devices
  463.   see the "scout" word in Systems ?  That tells which dialer to use in
  464.   Dialers.
  465.  
  466.   If you had a ACU port, but none that matched the specified dialer on
  467.   the same line in Systems, you'll get that message.
  468.  
  469.  
  470.   5.5.    What are known good config files for HDB mode ?
  471.  
  472.   The following are "known-good" config files for Taylor 1.05 under
  473.   Linux in HoneyDanBer mode.  They work on kernels of 0.99-8 or later.
  474.   All files should be in /usr/lib/uucp unless you've tweaked the sources
  475.   to put the uucp library elsewhere.
  476.  
  477.   If you *HAVE* put things in non-standard places, be aware that things
  478.   like sendmail might get very confused. You need to ensure that all
  479.   communications-related programs agree on your idea of "standard"
  480.   paths.
  481.  
  482.   If you're running a kernel of 0.99-7 or earlier, change "cua1" to
  483.   "ttyS1".
  484.  
  485.  
  486.  
  487.  
  488.  
  489.  
  490.  
  491.  
  492.  
  493.  
  494.  
  495.  
  496.  
  497.  
  498.  
  499.  
  500.  
  501.  
  502.  
  503.  
  504.  
  505.  
  506.  
  507.  
  508.  
  509.  
  510.  
  511.  
  512.  
  513.  
  514.  
  515.  
  516.  
  517.  
  518.  
  519.  
  520.  
  521.  
  522.  
  523.  
  524.  
  525.  
  526.  
  527.  
  528.  
  529.   #------------- Devices -------------
  530.   # make sure the device (cua1 here) matches your system
  531.   # cua1 = COM2
  532.   #
  533.   # here "scout" is the Digicom Scout Plus 19.2 modem I use
  534.   # tbfast etc. is for a Telebit Trailblazer Plus modem's various speeds
  535.   #
  536.   ACU cua1 - 19200 scout
  537.   ACU cua1 - 9600 tbfast
  538.   ACU cua1 - 1200 tbslow
  539.   ACU cua1 - 2400 tbmed
  540.  
  541.   #------------- dialers --------------
  542.   # note the setting of the Trailblazer registers "on the fly"
  543.   # "scout" is a Digicom Scout Plus (Hayes-like) modem I use here
  544.   #
  545.   scout    =W-,    "" ATM0DT\T CONNECT
  546.   tbfast  =W-,    "" A\pA\pA\pT OK ATS50=255DT\T CONNECT\sFAST
  547.   tbslow  =W-,    "" A\pA\pA\pT OK ATS50=2DT\T CONNECT\s1200
  548.   tbmed    =W-,    "" A\pA\pA\pT OK ATS50=3DT\T CONNECT\s2400
  549.  
  550.   #-------------- Systems -------------
  551.   # this is a very generic entry that will work for most systems
  552.   #
  553.   # the Any;1 means that you can call once per minute with using -f (force)
  554.   # the ACU,g means force "g" protocol rather than Taylor's default "i"
  555.   #
  556.   fredsys Any;1 ACU,g 19200 scout5555555 "" \r ogin:--ogin: uanon word: uanon
  557.  
  558.   #-------------------------------- Permissions -------------------------
  559.  
  560.   # Taylor UUCP in HDB mode appears to be sensitive to blank lines.
  561.   # Make sure all Permissions lines are real or commented out.
  562.   #
  563.   # this is a anonymous uucp entry
  564.   #
  565.   LOGNAME=nuucp MACHINE=OTHER \
  566.   READ=/usr/spool/uucp/nuucp \
  567.   WRITE=/usr/spool/uucp/nuucp \
  568.   SENDFILES=yes REQUEST=yes \
  569.   COMMANDS=/bin/rmail
  570.   #
  571.   # this is a normal setup for a remote system that talks to us
  572.   # note the absolute path to rnews since this site puts things
  573.   # in locations that aren't "standard"
  574.   #
  575.   LOGNAME=fredsys MACHINE=fredsys \
  576.   READ=/usr/spool/uucp/fredsys:/usr/spool/uucp/uucppublic:/files \
  577.   WRITE=/usr/spool/uucp/fredsys:/usr/spool/uucppublic \
  578.   SENDFILES=yes REQUEST=yes \
  579.   COMMANDS=/bin/rmail:/usr/local/lib/news/bin/rnews
  580.   #----------------------------------------------------------------------
  581.  
  582.  
  583.  
  584.   5.6.    Getting uucico to call alternate numbers
  585.  
  586.   The new v1.05 has an added '-z' switch to uucico that will try
  587.   alternate numbers for a remote system.
  588.  
  589.   6.  Acknowledgements
  590.  
  591.  
  592.   The following people have helped in the assembly of the information
  593.   (and experience) that helped make this document possible:
  594.  
  595.   Ed Carp, Steve Robbins, Ian Taylor, Greg Naber, Matt Welsh, Pierre
  596.   Beyssac
  597.  
  598.   If I forgot anybody, my apologies.
  599.  
  600.  
  601.  
  602.  
  603.  
  604.  
  605.  
  606.  
  607.  
  608.  
  609.  
  610.  
  611.  
  612.  
  613.  
  614.  
  615.  
  616.  
  617.  
  618.  
  619.  
  620.  
  621.  
  622.  
  623.  
  624.  
  625.  
  626.  
  627.  
  628.  
  629.  
  630.  
  631.  
  632.  
  633.  
  634.  
  635.  
  636.  
  637.  
  638.  
  639.  
  640.  
  641.  
  642.  
  643.  
  644.  
  645.  
  646.  
  647.  
  648.  
  649.  
  650.  
  651.  
  652.  
  653.  
  654.  
  655.  
  656.  
  657.  
  658.  
  659.  
  660.  
  661.